Custom Logging Messages তৈরি করা

Java Technologies - লগ4জে (log4j) - Log4j এ Custom Logging Messages
138

Log4j একটি জনপ্রিয় এবং শক্তিশালী লগিং ফ্রেমওয়ার্ক যা Java প্রোগ্রামিং ভাষায় লগিং কার্যক্রম পরিচালনা করতে ব্যবহৃত হয়। এটি আপনাকে লগ বার্তা কাস্টমাইজ করতে, বিভিন্ন লেভেলে (INFO, DEBUG, ERROR ইত্যাদি) লগিং করতে এবং বিভিন্ন আউটপুট উৎস (যেমন কনসোল, ফাইল, ডেটাবেস) এ লগ পাঠাতে সহায়তা করে। Custom Logging Messages তৈরি করার মাধ্যমে আপনি আপনার লগিং প্রক্রিয়াটিকে আরও স্পষ্ট, কার্যকর এবং বোধগম্য করে তুলতে পারেন।

এই টিউটোরিয়ালে, আমরা দেখব কিভাবে Log4j এর মাধ্যমে Custom Logging Messages তৈরি করা যায় এবং সেই সাথে এটি কিভাবে কনফিগার করা যায়।


১. Log4j ব্যবহার শুরু করা

Log4j ব্যবহার করতে, প্রথমে আপনাকে Log4j এর ডিপেনডেন্সি আপনার Maven বা Gradle প্রোজেক্টে যোগ করতে হবে।

Maven Dependency:

<dependencies>
    <!-- Log4j Dependency -->
    <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-api</artifactId>
        <version>2.14.1</version>
    </dependency>
    <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-core</artifactId>
        <version>2.14.1</version>
    </dependency>
</dependencies>

Gradle Dependency:

dependencies {
    implementation 'org.apache.logging.log4j:log4j-api:2.14.1'
    implementation 'org.apache.logging.log4j:log4j-core:2.14.1'
}

এখানে, log4j-api এবং log4j-core ডিপেনডেন্সি ব্যবহার করা হয়েছে, যা Log4j ফ্রেমওয়ার্কের জন্য প্রয়োজনীয়।


২. Log4j কনফিগারেশন (log4j2.xml)

Log4j ব্যবহার করতে হলে আপনাকে একটি কনফিগারেশন ফাইল তৈরি করতে হবে (যেমন log4j2.xml)। এই ফাইলে আপনি লগিং লেভেল, আউটপুট ফরম্যাট, এবং লগিং স্থান কনফিগার করতে পারেন।

উদাহরণ: log4j2.xml

<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="WARN">
    <Appenders>
        <!-- Console Appender: logs to the console -->
        <Console name="Console" target="SYSTEM_OUT">
            <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss} [%t] %-5level %logger{36} - %msg%n" />
        </Console>

        <!-- File Appender: logs to a file -->
        <File name="File" fileName="logs/app.log">
            <PatternLayout>
                <Pattern>%d{ISO8601} [%-5level] %logger{36} - %msg%n</Pattern>
            </PatternLayout>
        </File>
    </Appenders>

    <Loggers>
        <!-- Root logger: defines logging level and appender -->
        <Root level="debug">
            <AppenderRef ref="Console" />
            <AppenderRef ref="File" />
        </Root>
    </Loggers>
</Configuration>

এখানে:

  • Console Appender কনসোলে লগ আউটপুট করার জন্য কনফিগার করা হয়েছে।
  • File Appender একটি লগ ফাইল app.log তৈরি করে সেখানে লগ লেখার জন্য ব্যবহৃত হচ্ছে।
  • PatternLayout ফরম্যাট ব্যবহার করে, যেখানে লগের তারিখ, লেভেল, লগার এবং বার্তা আউটপুট হয়।

৩. Log4j এর মাধ্যমে Custom Logging Messages

Log4j ব্যবহার করে কাস্টম লগিং বার্তা তৈরি করার জন্য, আপনাকে Logger ইন্টারফেস ব্যবহার করতে হবে। আপনি বিভিন্ন লেভেলে লগ বার্তা তৈরি করতে পারেন যেমন INFO, DEBUG, ERROR, WARN, এবং TRACE

উদাহরণ: Custom Log Messages

import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;

public class CustomLoggerExample {
    
    // Create a logger instance
    private static final Logger logger = LogManager.getLogger(CustomLoggerExample.class);

    public static void main(String[] args) {
        
        // Custom info log
        logger.info("This is an info message: Application started.");
        
        // Custom debug log
        logger.debug("This is a debug message: Application debug initiated.");
        
        // Custom error log
        try {
            int result = 10 / 0;
        } catch (ArithmeticException e) {
            logger.error("This is an error message: Division by zero occurred.", e);
        }
        
        // Custom warn log
        logger.warn("This is a warning message: Something may be wrong with the configuration.");
        
        // Custom trace log
        logger.trace("This is a trace message: Detailed trace for debugging.");
    }
}

এখানে:

  • logger.info(), logger.debug(), logger.error(), logger.warn(), এবং logger.trace() ব্যবহার করে বিভিন্ন লেভেলের কাস্টম লগ মেসেজ তৈরি করা হয়েছে।
  • ERROR লগের জন্য আমরা একটি ArithmeticException তৈরি করেছি এবং সেটির স্ট্যাক ট্রেস লগ করেছি।

৪. Custom Log Message Format

PatternLayout এর মাধ্যমে আপনি কাস্টম লগ ফরম্যাট তৈরি করতে পারেন, যা লগের আউটপুটকে আরও বেশি বোধগম্য এবং স্পষ্ট করে তোলে।

উদাহরণ: Custom Pattern

<PatternLayout>
    <Pattern>%d{yyyy-MM-dd HH:mm:ss} [%t] %-5level %logger{36} - %msg%n</Pattern>
</PatternLayout>

এখানে, %d{yyyy-MM-dd HH:mm:ss} লগের তারিখ এবং সময় আউটপুট করবে, %t থ্রেড নাম দেখাবে, %-5level লগের লেভেল (INFO, DEBUG, ERROR ইত্যাদি) দেখাবে, %logger{36} লগারের ক্লাস নাম দেখাবে, এবং %msg লগ মেসেজ আউটপুট করবে।

উদাহরণ: আরও কাস্টম ফরম্যাট

<PatternLayout>
    <Pattern>Timestamp: %d{yyyy-MM-dd HH:mm:ss} | Level: %-5level | Logger: %logger{1} | Message: %msg%n</Pattern>
</PatternLayout>

এখানে, %logger{1} শুধুমাত্র লগারের ক্লাস নামের প্রথম অংশ (যেমন Main ক্লাস থেকে M) দেখাবে।


৫. Log4j with Logback Integration

আপনি যদি Logback ব্যবহার করেন, তবে Logback এবং Log4j এর ইন্টিগ্রেশনও সহজ। একই কনফিগারেশন ব্যবহার করে আপনি Logback এবং Log4j এর মধ্যে পারফরম্যান্সের সুবিধা গ্রহণ করতে পারেন।


সারাংশ

Log4j একটি শক্তিশালী লগিং ফ্রেমওয়ার্ক যা Java প্রোগ্রামে বিভিন্ন লগ মেসেজ এবং লেভেল কাস্টমাইজ করার সুবিধা প্রদান করে। Custom Logging Messages তৈরি করার মাধ্যমে আপনি লগ আউটপুটকে আরও বোধগম্য এবং কার্যকরী করে তুলতে পারেন। Log4j এর কনফিগারেশন ফাইলের মাধ্যমে আপনি কাস্টম আউটপুট ফরম্যাট তৈরি করতে পারেন এবং বিভিন্ন Appender ব্যবহার করে লগগুলো কনসোল বা ফাইলে রেকর্ড করতে পারেন। এছাড়াও, PatternLayout ব্যবহার করে আপনি লগ মেসেজের ফরম্যাট কাস্টমাইজ করতে পারবেন।


Content added By
Promotion
NEW SATT AI এখন আপনাকে সাহায্য করতে পারে।

Are you sure to start over?

Loading...